package com.tju.ocean_ecology_website.dao;

import com.tju.ocean_ecology_website.entity.VolunteerCommentLike;
import org.apache.ibatis.annotations.Param;
import java.util.List;

/**
 * 评论点赞表(VolunteerCommentLike)表数据库访问层
 *
 * @author shaolong
 * @since 2025-05-05 10:00:00
 */
public interface VolunteerCommentLikeDao {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    VolunteerCommentLike queryById(Long id);

    /**
     * 新增数据
     *
     * @param volunteerCommentLike 实例对象
     * @return 影响行数
     */
    int insert(VolunteerCommentLike volunteerCommentLike);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 影响行数
     */
    int deleteById(Long id);

    /**
     * 查询用户是否点赞评论
     *
     * @param userId 用户ID
     * @param commentId 评论ID
     * @return 点赞记录
     */
    VolunteerCommentLike queryByUserAndComment(@Param("userId") Long userId, @Param("commentId") Long commentId);

    /**
     * 删除用户对评论的点赞
     *
     * @param userId 用户ID
     * @param commentId 评论ID
     * @return 影响行数
     */
    int deleteByUserAndComment(@Param("userId") Long userId, @Param("commentId") Long commentId);

    /**
     * 查询评论的点赞用户列表
     *
     * @param commentId 评论ID
     * @return 点赞用户ID列表
     */
    List<Long> queryLikeUsersByComment(@Param("commentId") Long commentId);
}
